## **Digital System Design**

**Submission Date:** 1st Nov, 2019

Q1: Design a datapath with three 8 bit accumulators. The first accumulator, acc1, adds a 4 bit input data in acc1 in every clock cycle. The second accumulator, acc2, adds the first accumulator in itself, and the third accumulator, acc3, adds the first and second accumulators in itself in every clock cycle. Each accumulator has an asynchronous reset. Draw the RTL level diagram and code the design in RTL Verilog.

Q2: Exercise question 2.10. Provide an RTL diagram and its relevant code; also test your code using a stimulus. Keep the input and output bit size equal to 4 bits.

Q3: Complete the waveform for the given logic

```
module my_unit(clk, x, y1, y2);
input clk, x;
output y1, y2;
reg y1, y2;
wire w;
assign w = x | (^y1);
always@(posedge clk) y2 <= w;
always@(negedge clk) y1 <=y2;
endmodule
```



Q4: Write RTL Verilog Code for a BCD to 7-segment decoder. The module will accept a BCD number and it should provide bit value to relevant segment so that turn on relevant number can be displayed.

Assume 7-segment to be active low.



## **NOTE:**

- Assignment is a form of learning, please consider this while solving.
- Code should be properly <u>indented</u> and <u>commented</u>.
- Write your <u>code in MODELSIM</u>, verify it using <u>stimulus</u> and <u>attach output screen shots of your simulation</u> in a separate docx file. Code/Screen shots should not be copied, <u>in case of copying assignment will not be marked.</u>
- MODELSIM Projects (VERILOG files and all) along with screen shots of your simulation results should be *emailed as a single ".rar" file* on assignments.sajid@gmail.com.
- RAR file should be named as "YOURNAME\_ASSIGN#\_DSD".
- Subject of your <u>email MUST</u> be as <u>"YOURNAME\_ASSIGN#\_DSD"</u>.
- <u>VERY IMPORTANT:</u> RTL diagrams should either be drawn in VISIO for software submission, for submission in hard form draw the RTL diagrams with your <u>HANDS instead</u> <u>of FEET.</u>